The levels in Sokoban 3D are organized into sets. Each set that isn't built in to the game has its own set file.
The easiest way to make a new set file (and levels) is to use a Sokoban 3D-compatible level editor such as Franz Stadler's "Sokoban Level Editor." Franz Stadler can be reached at <fstadler@access.ch>. In addition, his Sokoban 3D-compatible Level Editor will soon be available on the Sokoban 3D home page (see the Sokoban 3D ReadMe file for the URL).
However, if you want to edit them yourself, and are handy with ResEdit, here's the information you'll need:
The set files consist of two resource types:
•The first is a standard 'TEXT' resource type which contains a bunch of text resources -- one for each level. You can (optionally) give each 'TEXT' resource a name which will be used as the name of the level by Sokoban 3D. The 'TEXT' resources are layed out according to the standard Sokoban level file format which uses ASCII characters to represent floors, walls, boxes, etc. See below for a description of this layout.
•You may use one of two other resources to specify the name of the set and the resource ID's of the first and last 'TEXT' levels. You should include either one or the other of these two resources. Sokoban 3D 1.0 only understands the 'SETs' resource. Sokoban 3D 1.0.1 will understand either the 'SETs' resource or the 'Setx' resource.
To use the 'SETs' resource, open the Sokoban 3D program with ResEdit. In there you will find the correct ResEdit 'SETs' template. Copy this template into the ResEdit preferences file. Create a 'SETs' resource with an ID of 128 in your new set file. Enter the name of the set and the resource IDs of the 'TEXT' resource of the first level and the last level in the set. That's it.
The 'Setx' resource is text-based. To use the 'Setx' resource, you can either type directly into the hex editor or create an 'RMAP' resource in ResEdit preferences remapping the 'Setx' resource to the 'TEXT' editor. The layout of the 'Setx' resource is similar to the 'SETs' resource. On the first line, type 1. Then go to a new line by pressing return (or adding the byte '0D' in the hex editor). Type the name of the set. Press return. Type the number of the resource ID of the first level's 'TEXT' resource. Press return. Type in the number of the resource ID of the last level's 'TEXT' resource. Finally, add a trailing return. (As opposed to the 'SETs' resource, the numbers here are stored as ASCII numbers, not as byte code.)
The set file itself should have a creator of 'Sk3d' and a type of 'Sets'.
Once you've succesfully made a set file and double-checked it against the information given here, drag it into the "Sets ƒ" folder in Sokoban 3D. The next time you start Sokoban, it should appear in the "Sets" menu.
Making Levels
Here's the layout of the TEXT resources that specify each level. This is a standard layout used by most implementations of Sokoban.
Each "cell" in the level (each square in the grid when viewed from the top-down as, e.g. in the "Map Mode" in Sokoban 3D), is represented by a single ASCII character. These characters are organized into lines separated by return characters. The top-most line refers to the top-most row of squares in the grid and so on.
The ASCII character codes are as follows:
' ' (space): Floor
'#' (pound): Wall
'$' (dollar sign): Box
'.' (period): Pallette
'@' ("at" symbol): Player
'*' (asterisk): Box on a pallette
'+': (plus): Player on a pallette
There must only be one player per level (either '@' or '+'). The level playing area should be completely surrounded by walls. The number of rows should not exceed 32 and neither should the number of columns.
Here's an example (this is the first level from the original set of 50 levels):
#####
# #
#$ #
### $##
# $ $ #
### # ## # ######
# # ## ##### ..#
# $ $ ..#
##### ### #@## ..#
# #########
#######
Notice that you don't need to add spaces to the end of a row if you've reached the end of the board but you must add spaces to the beginning to make sure everything lines up correctly.
When you add the 'TEXT' resource to ResEdit, it might be confusing since it may use a variable-width font. For instance, the above example could look like:
#####
# #
#$ #
### $##
# $ $ #
### # ## # ######
# # ## ##### ..#
# $ $ ..#
##### ### #@## ..#
# #########
#######
So it's probably best to design your levels in a fixed-width font like Monaco or Courier and then import them to ResEdit by copying and pasting.